-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathVsnwprintf.c
88 lines (71 loc) · 2.97 KB
/
Vsnwprintf.c
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
/*++
toro C Library
https://github.com/KilianKegel/toro-C-Library#toro-c-library-formerly-known-as-torito-c-library
Copyright (c) 2017-2025, Kilian Kegel. All rights reserved.
SPDX-License-Identifier: GNU General Public License v3.0
Module Name:
Vsnwprintf.c
Abstract:
Implementation of the Microsoft C function.
Write formatted output using a pointer to a list of arguments.
Author:
Kilian Kegel
--*/
#include <CdeServices.h>
#include <limits.h>
extern void* __cdeGetAppIf(void);
extern void _CdeMemPutWChar(int c, void** ppDest);
extern void _CdeMemPutNada(int c, void** ppDest);
static ROMPARM_VWXPRINTF RomParm = { \
/*fForceToDataSeg */ 1 ,\
/*fPointerIsParm */ 1 ,\
/*fPointerIsFilePointer */ 0 ,\
/*fCountIsParm; */ 1 ,\
/*fAjustDifference */ 0 ,\
/*fWide */ 1 ,\
/*fUEFIFormat */ 0, \
};
/**
Synopsis
#include <stdio.h>
int vsnwprintf(wchar_t* pszDest, size_t dwCount, const wchar_t* pszFormat, va_list ap);
Description
https://docs.microsoft.com/en-us/cpp/c-runtime-library/reference/vsnprintf-vsnprintf-vsnprintf-l-vsnwprintf-vsnwprintf-l?view=msvc-160&viewFallbackFrom=vs-2019
Parameters
https://docs.microsoft.com/en-us/cpp/c-runtime-library/reference/vsnprintf-vsnprintf-vsnprintf-l-vsnwprintf-vsnwprintf-l?view=msvc-160#parameters
Returns
https://docs.microsoft.com/en-us/cpp/c-runtime-library/reference/vsnprintf-vsnprintf-vsnprintf-l-vsnwprintf-vsnwprintf-l?view=msvc-160#return-value
**/
int _vsnwprintf(wchar_t* pszDest, size_t dwCount, const wchar_t* pszFormat, va_list ap) {
//NOTE: dwCount == INT_MAX -> buffer unlimited sprintf() is invoked w/o snprintf() constant return value of (theoretical) length
unsigned nRet = UINT_MAX;
CDE_APP_IF* pCdeAppIf = __cdeGetAppIf();
unsigned dwUsedCount = (unsigned)dwCount;
void (*pfnPutXxx)(int c, void** ppDest) = &_CdeMemPutWChar;
do {
if (pszDest == NULL)
if (dwCount == 0)
dwUsedCount = UINT_MAX, pfnPutXxx = &_CdeMemPutNada; // count only, don't write
else
break;
nRet = (int)pCdeAppIf->pCdeServices->pVwxPrintf(
pCdeAppIf, //this
&RomParm, //IN ROMPARM_VWXPRINTF *pRomParm,
pszFormat, //IN const void *pszFormat,
pfnPutXxx, //void (*pfnDevPutChar)(UINT16/*wchar_t*/c,void** ppDest/*address of pDest*/),
pszDest, //UINT8 *pDest,
(unsigned)dwUsedCount, //unsigned dwCount,
ap //IN va_list ap
);
if (pszDest != NULL) {
if (dwUsedCount > nRet&& nRet != UINT_MAX)
pszDest[nRet] = L'\0';
if (dwCount != INT_MAX && (nRet == UINT_MAX || dwCount == nRet)) {
if (dwCount)
pszDest[dwCount - 1] = L'\0';
nRet = _vsnwprintf(NULL, 0, pszFormat, ap);
}
}
} while (0);
return (int)nRet;
}